import router, { resetRouter } from './router'
import store from './store'
import storage from 'store'
import NProgress from 'nprogress' // progress bar
import '@/components/NProgress/nprogress.less' // progress bar custom style
import notification from 'ant-design-vue/es/notification'
import { setDocumentTitle, domTitle } from '@/utils/domUtil'
import { ACCESS_TOKEN } from '@/store/mutation-types'

NProgress.configure({ showSpinner: false }) // NProgress Configuration

const allowList = ['resLogin','login','newsdetail','membership','register','recDetail','findServices','newsIndex','supermarket','settledEnt','aboutUs','serviceItems','Introduction','pubServices','cases','casesDetail','casesDetailItem','settledEntDetail','settledEntDetailItem','supDetail','supDetailItem'] // no redirect allowList
const loginRoutePath = '/reception/Introduction/index'
// const loginRoutePath = '/reslogin'
const defaultRoutePath = '/dashboard'
router.beforeEach((to, from, next) => {
  NProgress.start() // start progress bar
  to.meta && typeof to.meta.title !== 'undefined' && setDocumentTitle(`${to.meta.title} - ${domTitle}`)
  /* has token */
  const token = storage.get(ACCESS_TOKEN)
  if (token) {
    if (to.path === '/login') {
      next({ path: defaultRoutePath })
      NProgress.done()
    } else {
      // check login user.roles is null
      if ((from.path === '/reslogin') && store.getters.roles.length === 0) {
        store
        .dispatch('GetInfo')
        .then(res => {
          next()
          const routes = res.data.menuList
          // generate dynamic router
          store.dispatch('GenerateRoutes', routes).then(() => {
            // 根据roles权限生成可访问的路由表
            // 动态添加可访问路由表
            // VueRouter@3.5.0+ New API
            resetRouter() // 重置路由 防止退出重新登录或者token过期后页面未刷新，导致的路由重复添加
            store.getters.addRouters.forEach(r => {
              router.addRoute(r)
            })
            // 请求带有 redirect 重定向时，登录自动重定向到该地址
            // const redirect = decodeURIComponent(from.query.redirect || to.path)
            let redirect
            // 请求带有 redirect 重定向时，登录自动重定向到该地址
            if (store.state.user.roled.length === 0) {
              redirect = '/reception/findServices/index'
            }else {
              // redirect = decodeURIComponent(from.query.redirect || to.path)
              redirect = '/dashboard'
            }
            console.log('33333333333333333',redirect);
            // const redirect = '/reception/findServices/index'
            if (to.path === redirect) {
              console.log('1111111111',{ ...to, replace: true });
              // set the replace: true so the navigation will not leave a history record
              next({ ...to, replace: true })
            } else {
              // 跳转到目的路由
              console.log('22222222222222',redirect);
              next({ path: redirect })
            }
          })
        })
        .catch(() => {
          notification.error({
            message: '错误',
            description: '请求用户信息失败，请重试'
          })
          // 失败时，获取用户信息失败时，调用登出，来清空历史保留信息
          store.dispatch('Logout').then(() => {
            next({ path: loginRoutePath, query: { redirect: to.fullPath } })
          })
        })
      }
      else if (store.getters.roles.length === 0) {
        // request login userInfo
          store
          .dispatch('GetInfo')
          .then(res => {
            const routes = res.data.menuList
            // generate dynamic router
            store.dispatch('GenerateRoutes', routes).then(() => {
              // 根据roles权限生成可访问的路由表
              // 动态添加可访问路由表
              // VueRouter@3.5.0+ New API
              resetRouter() // 重置路由 防止退出重新登录或者token过期后页面未刷新，导致的路由重复添加
              store.getters.addRouters.forEach(r => {
                router.addRoute(r)
              })
              // 请求带有 redirect 重定向时，登录自动重定向到该地址
              const redirect = decodeURIComponent(from.query.redirect || to.path)
              // const redirect = '/reception/findServices/index'
              if (to.path === redirect) {
                // set the replace: true so the navigation will not leave a history record
                next({ ...to, replace: true })
              } else {
                // 跳转到目的路由
                next({ path: redirect })
              }
            })
          })
          .catch(() => {
            notification.error({
              message: '错误',
              description: '请求用户信息失败，请重试'
            })
            // 失败时，获取用户信息失败时，调用登出，来清空历史保留信息
            store.dispatch('Logout').then(() => {
              next({ path: loginRoutePath, query: { redirect: to.fullPath } })
            })
          })
      } else {
        next()
      }
    }
  } else {
    if (allowList.includes(to.name)) {
      // 在免登录名单，直接进入
      next()
    } else {
      next({ path: loginRoutePath, query: { redirect: to.fullPath } })
      NProgress.done() // if current page is login will not trigger afterEach hook, so manually handle it
    }
  }
})

router.afterEach(() => {
  NProgress.done() // finish progress bar
})
